## LCD Dot Matrix 16x2

HD44780U

#### **Features**

- $5 \times 8$  and  $5 \times 10$  dot matrix possible
- • Low power operation support:
- 2.7 to 5.5V
- Wide range of liquid crystal display driver power
- 23.0 to 11V
- Liquid crystal drive waveform
- 2 A (One line frequency AC waveform)
- Correspond to high speed MPU bus interface
- 2 MHz (when VCC = 5V)
- 4-bit or 8-bit MPU interface enabled
- • 80 × 8-bit display RAM (80 characters max.)
- • 9,920-bit character generator ROM for a total of 240 character fonts
- 2 208 character fonts (5 × 8 dot)
- 2 32 character fonts (5 × 10 dot)

#### **Features**

- 64 × 8-bit character generator RAM
- 28 character fonts (5 × 8 dot)
- 2 4 character fonts (5 × 10 dot)
- • 16-common × 40-segment liquid crystal display driver
- Programmable duty cycles
- 21/8 for one line of  $5 \times 8$  dots with cursor
- 21/11 for one line of  $5 \times 10$  dots with cursor
- 21/16 for two lines of  $5 \times 8$  dots with cursor
- Wide range of instruction functions:
- Display clear, cursor home, display on/off, cursor on/off, display character blink, cursor shift,
- display shift
- Pin function compatibility with HD4478oS
- Automatic reset circuit that initializes the controller/driver after power on
- Internal oscillator with external resistors
- Low power consumption

## PIN

| Signal                | Lines | I/O | Interfaced with            | Function                                                                                                                                                                                                  |
|-----------------------|-------|-----|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RS                    | 1     | I   | MPU                        | Selects registers. 0: Instruction register (for write) Busy flag: address counter (for read) 1: Data register (for write and read)                                                                        |
| R/W                   | 1     | I   | MPU                        | Selects read or write. 0: Write 1: Read                                                                                                                                                                   |
| E                     | 1     | T   | MPU                        | Starts data read/write.                                                                                                                                                                                   |
| DB4 to DB7            | 4     | I/O | MPU                        | Four high order bidirectional tristate data bus pins. Used for data transfer and receive between the MPU and the HD44780U. DB7 can be used as a busy flag.                                                |
| DB0 to DB3            | 4     | I/O | MPU                        | Four low order bidirectional tristate data bus pins. Used for data transfer and receive between the MPU and the HD44780U. These pins are not used during 4-bit operation.                                 |
| CL1                   | 1     | 0   | Extension driver           | Clock to latch serial data D sent to the extension driver                                                                                                                                                 |
| CL2                   | 1     | 0   | Extension driver           | Clock to shift serial data D                                                                                                                                                                              |
| М                     | 1     | 0   | Extension driver           | Switch signal for converting the liquid crystal drive waveform to AC                                                                                                                                      |
| D                     | 1     | 0   | Extension driver           | Character pattern data corresponding to each<br>segment signal                                                                                                                                            |
| COM1 to COM16         | 16    | 0   | LCD                        | Common signals that are not used are changed to non-selection waveforms. COM9 to COM16 are non-selection waveforms at 1/8 duty factor and COM12 to COM16 are non-selection waveforms at 1/11 duty factor. |
| SEG1 to SEG40         | 40    | 0   | LCD                        | Segment signals                                                                                                                                                                                           |
| V1 to V5              | 5     | _   | Power supply               | Power supply for LCD drive V <sub>cc</sub> –V5 = 11 V (max)                                                                                                                                               |
| V <sub>cc</sub> , GND | 2     | _   | Power supply               | V <sub>cc</sub> : 2.7V to 5.5V, GND: 0V                                                                                                                                                                   |
| OSC1, OSC2            | 2     | _   | Oscillation resistor clock | When crystal oscillation is performed, a resistor must be connected externally. When the pin input is an external clock, it must be input to OSC1.                                                        |

### **ASCII**

| Lower Bits<br>4 Bits | 0000             | 0001 | 0010        | 0011 | 0100      | 0101       | 0110 | 0111        | 1000 | 1001 | 1010 | 1011       | 1100      | 1101                                    | 1110        | 1111        |
|----------------------|------------------|------|-------------|------|-----------|------------|------|-------------|------|------|------|------------|-----------|-----------------------------------------|-------------|-------------|
| xxxx0000             | CG<br>RAM<br>(1) |      |             | 9    | <u>a</u>  | <b> </b> ' |      | ļ=:·        |      |      |      |            | :9        | <b>≡</b> .                              | O.          |             |
| xxxx0001             | (2)              |      | i           | 1    | <b>  </b> | Ü.         | .3   | -=-         |      |      | 13   | 77         | <b>;</b>  | <u></u> :                               | .≝.         |             |
| xxxx0010             | (3)              |      | 11          | 2    |           | 17.        | b    | ŗ           |      |      | · ·  | 4          | ij        | ×                                       | <b>j</b> ≅  | ⊜           |
| xxxx0011             | (4)              |      | #           |      |           | 5          | C    | 5           |      |      | .!   | ņ          | Ŧ         | 垩                                       | :Ξ.         | ::0         |
| xxxx0100             | (5)              |      | \$          | 4    | D         | <b>"</b>   | d    | t.          |      |      | ν.   | I          | ŀ.        | <b>†</b> :                              | <b>]</b> i  | 572         |
| xxxx0101             | (6)              |      | 7.          | 5    |           |            | ₽    | i_i         |      |      | •    | 7          | <b>;</b>  | ].                                      | (3)         | Ü           |
| xxxx0110             | (7)              |      | 8:          | 6    | <b>!</b>  | V          | f    | V           |      |      | 7    | <b>j</b> ŋ |           | ======================================= | P           | Ξ           |
| xxxx0111             | (8)              |      |             | 7    | <u> </u>  | W          | 9    | W           |      |      | 7    | #          | 77        | <b>;</b>                                |             | Л           |
| xxxx1000             | (1)              |      | (           | 8    | <b>  </b> | X          | 'n   | ×           |      |      | 4    | 7          | #         | ij                                      | .,          | X           |
| xxxx1001             | (2)              |      | )           | 9    | I         | Υ          | i    | <b>'</b> ;; |      |      | ::5  | Ţ          | ļ         | ĮĮ.                                     | i           | <u>!_ </u>  |
| xxxx1010             | (3)              |      | *           | #    | J         | Z          | j    | Z           |      |      | I    |            | ١'n       | Ļ                                       | .1          | <b>::</b>   |
| xxxx1011             | (4)              |      | <b>-</b> †- | ;    | K         |            | k    | <           |      |      | 7    | <b>#</b>   | <u>t-</u> |                                         | ×           | <b>;=</b> ; |
| xxxx1100             | (5)              |      |             | <    | <u>L.</u> | #          | 1    |             |      |      | †7   | =,         | 7         | <b>"</b>                                | <b>:</b> ‡. | =           |
| xxxx1101             | (6)              |      |             | ===  | M         | ]          | m    | <b>}</b>    |      |      | .=   | Z          |           | :                                       | #           | -÷-         |
| xxxx1110             | (7)              |      |             | >    | ŀ·ļ       | •••        | n    | ÷           |      |      | ∄    | 世          | #         | •••                                     | F           |             |
| xxxx1111             | (8)              |      | /           |      |           |            | 0    | ÷           |      |      | .:1  | y          | 7         |                                         | Ö           |             |

Note: The user can specify any pattern for character-generator RAM.

# Interfacing to the MPU

- The HD4478oU can send data in either two 4-bit operations or one 8-bit operation, thus allowing
- interfacing with 4- or 8-bit MPUs.
- For 4-bit interface data, only four bus lines (DB4 to DB7) are used for transfer. Bus lines DBo to DB3 are disabled. The data transfer between the HD44780U and the MPU is completed after the 4-bit data has been transferred twice. As for the order of data transfer, the four high order bits (for 8-bit operation, DB4 to DB7) are transferred before the four low order bits (for 8-bit operation, DBo to DB3).
- The busy flag must be checked (one instruction) after the 4-bit data has been transferred twice. Two
- more 4-bit operations then transfer the busy flag and address counter data.
- • For 8-bit interface data, all eight bus lines (DBo to DB7) are used.



### Initializing by Internal Reset Circuit

An internal reset circuit automatically initializes the HD44780U when the power is turned on. The following instructions are executed during the initialization. The busy flag (BF) is kept in the busy state until the initialization ends (BF = 1). The busy state lasts for 10 ms after  $V_{\rm CC}$  rises to 4.5 V.

- Display clear
- 2. Function set:

DL = 1; 8-bit interface data

N = 0; 1-line display

F = 0;  $5 \times 8$  dot character font

3. Display on/off control:

D = 0; Display off

C = 0; Cursor off

B = 0; Blinking off

4. Entry mode set:

I/D = 1; Increment by 1

S = 0; No shift

Note: If the electrical characteristics conditions listed under the table Power Supply Conditions Using Internal Reset Circuit are not met, the internal reset circuit will not operate normally and will fail to initialize the HD44780U. For such a case, initial-ization must be performed by the MPU as explained in the section, Initializing by Instruction.

### Instruksi

|                                |    |     | Code |     |     |     |     |     |     |     |                                                                                                                                                        | Execution Time (max) (when f <sub>cp</sub> or |  |  |
|--------------------------------|----|-----|------|-----|-----|-----|-----|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--|--|
| Instruction                    | RS | R/W | DB7  | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | Description                                                                                                                                            | f <sub>osc</sub> is 270 kHz)                  |  |  |
| Clear<br>display               | 0  | 0   | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 1   | Clears entire display and<br>sets DDRAM address 0 in<br>address counter.                                                                               |                                               |  |  |
| Return<br>home                 | 0  | 0   | 0    | 0   | 0   | 0   | 0   | 0   | 1   | _   | Sets DDRAM address 0 in<br>address counter. Also<br>returns display from being<br>shifted to original position.<br>DDRAM contents remain<br>unchanged. | 1.52 ms                                       |  |  |
| Entry<br>mode set              | 0  | 0   | 0    | 0   | 0   | 0   | 0   | 1   | I/D | S   | Sets cursor move direction<br>and specifies display shift.<br>These operations are<br>performed during data write<br>and read.                         | 37 μs                                         |  |  |
| Display<br>on/off<br>control   | 0  | 0   | 0    | 0   | 0   | 0   | 1   | D   | С   | В   | Sets entire display (D) on/off, cursor on/off (C), and blinking of cursor position character (B).                                                      | 37 μs                                         |  |  |
| Cursor or display shift        | 0  | 0   | 0    | 0   | 0   | 1   | S/C | R/L | _   | _   | Moves cursor and shifts display without changing DDRAM contents.                                                                                       | 37 μs                                         |  |  |
| Function set                   | 0  | 0   | 0    | 0   | 1   | DL  | N   | F   | _   | _   | Sets interface data length (DL), number of display lines (N), and character font (F).                                                                  | 37 μs                                         |  |  |
| Set<br>CGRAM<br>address        | 0  | 0   | 0    | 1   | ACG | ACG | ACG | ACG | ACG | ACG | Sets CGRAM address.<br>CGRAM data is sent and<br>received after this setting.                                                                          | 37 μs                                         |  |  |
| Set<br>DDRAM<br>address        | 0  | 0   | 1    | ADD | Sets DDRAM address.<br>DDRAM data is sent and<br>received after this setting.                                                                          | 37 μs                                         |  |  |
| Read busy<br>flag &<br>address | 0  | 1   | BF   | AC  | Reads busy flag (BF) indicating internal operation is being performed and reads address counter contents.                                              | 0 μs                                          |  |  |

Execution Time

|                                  |                                                     |                                                                              | Code                                                                                                                                                                                       | _                                              |                                                                                                                                         | Execution Time (max) (when f <sub>cp</sub> or                                                                                                  |  |  |
|----------------------------------|-----------------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Instruction                      | RS                                                  | R/W                                                                          | DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0                                                                                                                                                            | Descript                                       | ion                                                                                                                                     | f <sub>OSC</sub> is 270 kHz)                                                                                                                   |  |  |
| Write data<br>to CG or<br>DDRAM  | 1                                                   | 0                                                                            | Write data                                                                                                                                                                                 | Writes da<br>CGRAM.                            | ata into DDRAM or                                                                                                                       | 37 μs<br>t <sub>ADD</sub> = 4 μs*                                                                                                              |  |  |
| Read data<br>from CG or<br>DDRAM | 1                                                   | 1                                                                            | Read data                                                                                                                                                                                  | Reads da<br>CGRAM.                             | ata from DDRAM or                                                                                                                       | 37 μs<br>t <sub>ADD</sub> = 4 μs*                                                                                                              |  |  |
|                                  | S<br>S/C<br>S/C<br>R/L<br>R/L<br>DL<br>N<br>F<br>BF | = 1:<br>= 0:<br>= 1:<br>= 0:<br>= 1:<br>= 0:<br>= 1:<br>= 1:<br>= 1:<br>= 0: | Accompanies display shift Display shift Cursor move Shift to the right Shift to the left 8 bits, DL = 0: 4 bits 2 lines, N = 0: 1 line 5 × 10 dots, F = 0: 5 × 8 dots Internally operating | ACG:<br>ADD:<br>(cor<br>add<br>AC: Add<br>both | Display data RAM Character generator RAM CGRAM address DDRAM address responds to cursor ress) ress counter used for DD and CGRAM resses | Execution time changes when frequency changes Example: When $f_{cp}$ or $f_{OSC}$ is 250 kHz, $37 \ \mu s \times \frac{270}{250} = 40 \ \mu s$ |  |  |

Note: — indicates no effect.

<sup>\*</sup> After execution of the CGRAM/DDRAM data write or read instruction, the RAM address counter is incremented or decremented by 1. The RAM address counter is updated after the busy flag turns off. In Figure 10, t<sub>ADD</sub> is the time elapsed after the busy flag turns off until the address counter is updated.

# Interfacing 8 bit

#### Interfacing the HD44780U

#### Interface to MPUs

Interfacing to an 8-bit MPU

See Figure 16 for an example of using a I/O port (for a single-chip microcomputer) as an interface device.

In this example, P30 to P37 are connected to the data bus DB0 to DB7, and P75 to P77 are connected to E,  $R/\overline{W}$ , and RS, respectively.



Figure 15 Example of Busy Flag Check Timing Sequence

## Interfacing 8 bit

#### Interfacing to a 4-bit MPU

The HD44780U can be connected to the I/O port of a 4-bit MPU. If the I/O port has enough bits, 8-bit data can be transferred. Otherwise, one data transfer must be made in two operations for 4-bit data. In this case, the timing sequence becomes somewhat complex. (See Figure 17.)

See Figure 18 for an interface example to the HMCS4019R.

Note that two cycles are needed for the busy flag check as well as for the data transfer. The 4-bit operation is selected by the program.

